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DETAILED ACTION 

1 . This Office Action is responsive to amendments filed in application No. 10/692,004 on 
August 26, 2008. Claims 1-20 are pending and have been examined. 



Claim Rejections - 35 USC §103 

2. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in 
section 102 of this title, if the differences betw een the subject matter sought to be patented and the prior art are 
such that the subject matter as a whole would have been obvious at the time the invention was made to a person 
having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 

The factual inquiries set forth in Graham v. John Deere Co., 383 U.S. 1, 148 USPQ 459 
(1966), that are applied for establishing a background for determining obviousness under 35 
U.S.C. 103(a) are summarized as follows: 

1 . Determining the scope and contents of the prior art. 

2. Ascertaining the differences between the prior art and the claims at issue. 

3. Resolving the level of ordinary skill in the pertinent art. 

4. Considering objective evidence present in the application indicating obviousness 
or nonobviousness. 



3. Claims 1-2, 4-10, 11-15 and 17-20 rejected under 35 U.S.C. 103(a) as being 

unpatentable over Morita ( 5,969,712 ) in view of Applicant's admitted prior art (AAPR) 



Morita teaches in Claim 1 : 

A process for transferring pen data between unmanaged and managed code on a 
computing device, the unmanaged code being code native to and executed directly by a 
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processor of the computing device ( Column 8, Lines 63-65, information processing unit to input 
the coordinate value ( read as unmanaged code is the raw data that needs to be converted before 
it can be used by the application. The unit is a processor. ) comprising the step of: 

receiving pen data in a component on the computing device written in unmanaged code, 
the pen data being generated by a digitzer of the computing device upon movement of a stylus 
with respect to a surface of the digitizer, the pen data including at least one location on the 
digitizer of the stylus ( Column 8, Lines 63-65, information processing unit to input the 
coordinate value (read unmanaged code is the raw data that needs to be converted before it can 
be used by the application), used in conjunction with the coordinate detecting section 21 to 
indicate points. Column 13, Lines 28-31 ); 

transferring information related to said pen data to a shared memory on the computing 
device designated to be shared between unmanaged code and managed code ( Column 9, Lines 
13-14 disclose a memory means for storing functional data, this data is based on the coordinates 
indicated by the user to help determine the appropriate function to select ); 

transferring, by the component written in unmanaged code, that points to said information 
in said shared memory to an application on the computing device written at least in part in 
managed code ( Column 9, Lines 14-21 disclose a conversion means and Column 22, Lines 40- 
43 disclose the data is converted in accordance to perform the assigned function, (read as being 
converted by a means to now be partly in managed code form to allow the function to be 
executed ); and 

retrieving, said information from said shared memory ( Column 9, Lines 13-14 disclose a 
memory means for manipulating the functional data ); but 
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However, Morita does not explicitly teach of the two types of codes "being executed in a 
common language run-time environment of a framework operating on the computing device, the 
common language run-time environment of the framework executing the managed code 
independent of a type of the processor of the computing device." Specifically, Morita does not 
teach of the CLR. However, such a framework is well known in the art. 

To emphasize, the prior art provided by Applicant, Figure 3 shows the common language run- 
time to manage the various types of codes, such as managed and unmanaged code. [0009] of the 
disclosure states that one may be motivated to use the CLR to transfer information (unmanaged 
code) to a managed application. 

Therefore, it would be obvious to one of ordinary skill in the art at the time of the invention to 
use the common language run-time environment of a framework to receive the coordinate data 
(unmanaged code) of Morita' s stylus input and to use its environment to convert the code for use 
with the appropriate application (managed code). The CLR is well known and is provided as 
prior art by the Applicant. The motivation is that is commonly used in the art and Applicant's 
disclosure makes for it to be enabling. 

Morita also does not explicitly teach of a pointer to reference different parts of the memory. 
However, pointers are well known for this function, to point to addresses for retrieval. Examiner 
takes Official Notice as to the use of these as they are well known in the art. 
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Morita teaches in Claim 2: 

The process according to claim 1, further comprising the steps of: 

transferring additional information from said at least in part managed application to said 
shared memory ( Abstract, conversion status output means 25 outputs data stored in the memory 
means 23, for data that is converted ); 

transferring a pointer that points to said additional information to said component 
( Column 9, Lines 13-14 disclose a memory which can be accessed ); 

retrieving said additional information from said shared memory. ( Column 9, Lines 13-14 
disclose a memory which can be accessed for functional data, repetitive for multiple stylus 
inputs) 

Morita teaches in Claim 4: 

The process according to claim 1, further comprising the step of: exchanging information 
through a COM interface. ( Column 8, Lines 63-65, information processing unit to input the 
coordinate value, used in conjunction with the coordinate detecting section 21 to indicate points. 
Column 13, Lines 28-31. This interacts with the stylus to determine the inputs ) 

Morita teaches in Claim 5 : 

The process according to claim 1 , said component being a pen services component. 
(Column 13, Lines 28-3 1 disclose the coordinate detecting section 21 to interact with the 
stylus/pen) 
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Morita teaches in Claim 6: 

The process according to claim 1, said application including a pen input managed client. 
(Column 8, Lines 63-65, information processing unit to input the coordinate value ) 

Morita teaches in Claim 7: 

The process according to claim 1 , said component receiving input from at least one pen 
device driver. ( Figure 2 shows a stylus 3 being used to input coordinates ) 

Morita teaches in Claim 8: 

A system for transferring information between unmanaged code and managed code on a 
computing device, the unmanaged code being code native to and executed directly by a 
processor of the computing device ( Column 8, Lines 63-65, information processing unit to input 
the coordinate value ( read as unmanaged code is the raw data that needs to be converted before 
it can be used by the application. The unit is a processor. ) comprising: 

a shared memory on the computing device designated to be shared between unmanaged 
code and managed code ( Column 9, Lines 13-14 disclose a memory means for storing functional 
data, this data is based on the coordinates indicated by the user to help determine the appropriate 
function to select ) 

a component on the computing deivce that is written in unmanaged code (coordinate 
data) and that receives pen data, the pen data being generated by a digitzer of the computing 
device upon movement of a stylus with respect to a surface of the digitizer, the pen data 
including at least one location on the digitizer of the stylus, the component transferring 
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information relating to said pen data to said shared memory and transfers points to said 
information in the shared memory to an application on the computing device having managed 
code ( Column 8, Lines 63-65, information processing unit to input the coordinate value (read 
unmanaged code is the raw data that needs to be converted before it can be used by the 
application), used in conjunction with the coordinate detecting section 21 to indicate points. 
Column 13, Lines 28-31 ) ( Column 9, Lines 14-21 disclose a conversion means and Column 22, 
Lines 40-43 disclose the data is converted in accordance to perform the assigned function, (read 
as being converted by a means to now be partly in managed code form to allow for the function 
to be executed ); 

said application having managed code receiving said pointer and obtaining said 
information from said shared memory. ( Column 9, Lines 13-14 disclose a memory means for 
manipulating the functional data ) 

However, Morita does not explicitly teach of the two types of codes "being executed in a 
common language run-time environment of a framework operating on the computing device, the 
common language run-time environment of the framework executing the managed code 
independent of a type of the processor of the computing device." Specifically, Morita does not 
teach of the CLR. However, such a framework is well known in the art. 

To emphasize, the prior art provided by Applicant, Figure 3 shows the common language run- 
time to manage the various types of codes, such as managed and unmanaged code. [0009] of the 
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disclosure states that one may be motivated to use the CLR to transfer information (unmanaged 
code) to a managed application. 

Therefore, it would be obvious to one of ordinary skill in the art at the time of the invention to 
use the common language run-time environment of a framework to receive the coordinate data 
(unmanaged code) of Morita's stylus input and to use its environment to convert the code for use 
with the appropriate application (managed code). The CLR is well known and is provided as 
prior art by the Applicant. The motivation is that is commonly used in the art and Applicant's 
disclosure makes for it to be enabling. 

Morita also does not explicitly teach of a pointer to reference different parts of the memory. 
However, pointers are well known for this function, to point to addresses for retrieval. Examiner 
takes Official Notice as to the use of these as they are well known in the art. 

Morita teaches in Claim 9: 

The system according to claim 8, said component exposing a COM interface. ( Column 8, 
Lines 63-65, information processing unit to input the coordinate value, used in conjunction with 
the coordinate detecting section 21 to indicate points. Column 13, Lines 28-31. This interacts 
with the stylus to determine the inputs) 

Morita teaches in Claim 1 1 : 
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The system according to claim 8, said component including a pen services component. 
( Column 13, Lines 28-31 disclose the coordinate detecting section 21 to interact with the 
stylus/pen ) 

Morita teaches in Claim 12: 

The system according to claim 8, further comprising: at least one pen device driver 
sending information to said component. (Figure 2 shows a stylus 3 being used to input 
coordinates ) 

Morita teaches in Claim 13: 

The system according to claim 8, further comprising: said application including a pen 
input managed client. (Column 8, Lines 63-65, information processing unit to input the 
coordinate value) 

Morita teaches in Claim 14: 

A computer-readable storage medium having a program stored thereon for transferring 
information related to ink between an unmanaged component and an application including 
managed code on a computing device, the unmanaged code being code native to and executed 
directly by a processor of the computing device ( Column 8, Lines 63-65, information processing 
unit to input the coordinate value ( read as unmanaged code is the raw data that needs to be 
converted before it can be used by the application. The unit is a processor. ), said program 
comprising the steps of ( Figure 2 shows a stylus input for a device): 
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receiving pen data in the unmanaged component on the computing device, the pen data 
being generated by a digitizer of the computing device upon movement of a stylus with respect 
to a surface of the digitizer, the pen data including at least one location on the digitzer of the 
stylus ( Column 8, Lines 63-65, information processing unit to input the coordinate value (read 
unmanaged code as raw data that needs to be converted before it can be used by the application), 
used in conjunction with the coordinate detecting section 21 to indicate points. Column 13, Lines 
28-31); 

transferring information related to said pen data to a shared memory on the computing 
device designated to be shared between unmanaged code and managed code ( Column 9, Lines 
13-14 disclose a memory means for storing functional data, this data is based on the coordinates 
indicated by the user to help determine the appropriate function to select ); 

transferring, by the unmanaged component, points to said information in said shared 
memory to an application written at least in part in managed code ( Column 9, Lines 14-21 
disclose a conversion means and Column 22, Lines 40-43 disclose the data is converted in 
accordance to perform the assigned function, (read as being converted by a means to now be 
partly in managed code form to allow the function to be executed ); and 

retrieving, by the managed code of the application, said information from said shared 
memory. ( Column 9, Lines 13-14 disclose a memory means for manipulating the functional 
data) 

However, Morita does not explicitly teach of the two types of codes "being executed in a 
common language run-time environment of a framework operating on the computing device, the 
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common language run-time environment of the framework executing the managed code 
independent of a type of the processor of the computing device." Specifically, Morita does not 
teach of the CLR. However, such a framework is well known in the art. 

To emphasize, the prior art provided by Applicant, Figure 3 shows the common language run- 
time to manage the various types of codes, such as managed and unmanaged code. [0009] of the 
disclosure states that one may be motivated to use the CLR to transfer information (unmanaged 
code) to a managed application. 

Therefore, it would be obvious to one of ordinary skill in the art at the time of the invention to 
use the common language run-time environment of a framework to receive the coordinate data 
(unmanaged code) of Morita' s stylus input and to use its environment to convert the code for use 
with the appropriate application (managed code). The CLR is well known and is provided as 
prior art by the Applicant. The motivation is that is commonly used in the art and Applicant's 
disclosure makes for it to be enabling. 

Morita also does not explicitl y teach of a pointer to reference different parts of the memory. 
However, pointers are well known for this function, to point to addresses for retrieval. Examiner 
takes Official Notice as to the use of these as they are well known in the art. 



Morita teaches in Claim 15: 



Application/Control Number: 10/692,004 Page 12 

Art Unit: 2629 

The computer-readable storage medium according to claim 14, said program further 
comprising the steps of: 

transferring additional information from said at least in part managed application to said 
shared memory ( Abstract, conversion status output means 25 outputs data stored in the memory 
means 23, for data that is converted ); 

transferring a pointer that points to said additional information to said component 
( Column 9, Lines 13-14 disclose a memory which can be accessed ); 

retrieving said additional information from said shared memory. ( Column 9, Lines 13-14 
disclose a memory means for manipulating the functional data ) 

Morita teaches in Claim 17: 

The computer-readable storage medium according to claim 14, said program further 
comprising the step of: exchanging information through a COM interface. ( Column 8, Lines 63- 
65, information processing unit to input the coordinate value. Used in conjunction with the 
coordinate detecting section 21 to indicate points. Column 13, Lines 28-31. This interacts with 
the stylus to determine the inputs ) 

Morita teaches in Claim 18: 

The computer-readable storage medium according to claim 14, said component being a 
pen services component. ( Column 13, Lines 28-31 disclose the coordinate detecting section 21 
to interact with the stylus/pen ) 
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Morita teaches in Claim 19: 

The computer-readable storage medium according to claim 14, said application including 
a pen input managed client. (Column 8, Lines 63-65, information processing unit to input the 
coordinate value ) 

Morita teaches in Claim 20: 

The computer-readable storage medium according to claim 14, said component receiving 
input from at least one pen device driver. ( Figure 2 shows a stylus 3 being used to input 
coordinates ) 

4. Claims 3, 10 and 16 rejected under 35 U.S.C. 103(a) as being unpatentable over Morita 
(5,969,712) 

As per Claims 3,10 and 16: 

These claims are directed to the use of a P-invoke style interface. Examiner takes Official 
Notice as to the use of P-invoke interfacing. This is common in the art as a software means. 

Response to Arguments 

Applicant's arguments considered, but are in moot in view of the new rejection. 

Applicant is thanked for the telephone conversation on July 30, 2008 and for discussing 
the key concepts of the invention. The objections for informalities has been removed since the 
amendments have cleared up this issue. 
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Applicant has amended to claim the common language run-time environment of the 
framework to better define how his managed and unmanaged code works. However, as currently 
claimed, the prior art as shown in Figure 3 of the disclosure contains a CLR with different 
boundaries for these two types of code. This reads upon the claim language for independent 
processing as well as two specific types of codes. [0009] of the dislcosure provides the details as 
well as the motivation for how and why one would want to use the CLR; this is well known in 
the art. The figure clearly shows the two types of code and the run-time environment and these 
two key components were the modified parts of the claims. 

Applicant is advised to better claim his invention. Figure 3 is the prior art and Figure 4 is 
Applicant's invention. Looking at the two figures, there are some differences, specifically in the 
pen input managed client 406 and the disclosure goes into some detail about it. It seems that the 
inventive concept is directed to this. Applicant is advised to claim this difference or at least claim 
it better to differentiate it from the prior art Morita and the prior art given by Applicant. 

Applicant's arguments considered, but are respectfully moot in view of the new rejection. 

Conclusions 

Applicant's amendment necessitated the new ground(s) of rejection presented in this 
Office action. Accordingly, THIS ACTION IS MADE FINAL. See MPEP 706.07(a). 
Applicant is reminded of the extension of time policy as set forth in 37 CFR 1.136(a) 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to DENNIS P. JOSEPH whose telephone number is (571)270-1459. 
The examiner can normally be reached on Monday-Friday, 8am-5pm. 
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If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Amr Awad can be reached on 571-272-7764. The fax phone number for the 
organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). If you would 
like assistance from a USPTO Customer Service Representative or access to the automated 
information system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 



DJ 

/Amr Awad/ 

Supervisory Patent Examiner, Art Unit 2629 



